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BACKGROUND 
This invention relates to wireless communication. 

A General Packet Radio Service (GPRS) network can provide mobile computing and telephony users with 

5 packet-switched connections to data networks. A subscriber with a mobile station can connect to other mobile 
stations or packet data networks to send and receive information. The information sent over the GPRS network is 
broken up into packets. A packet includes a header and a payload. The header can include instructions and 
information, such as error checking information, and source and destination addresses. The payload includes data 
that is to be delivered to the destination. 

10 As shown in FIG. I, a conventional GPRS network 100 can be used to connect one or more mobile stations 

1 15 to a packet data network, such as the Internet 173. A mobile station 1 1 5 can connect to a Serving GPRS 
Support Node (SGSN) 123, typically through a base station subsystem (not shown). A conventional base station 
subsystem is used to authenticate and track the mobile stations and manage connections. A public land mobile 
network (PLMN) can have multiple mobile stations and multiple SGSNs within its network. Packets can be 

15 transferred transparently between the mobile station and the Internet through GPRS network tunnels (i.e., GTP 
tunnels). A GTP tunnel is dynamically created between supporting nodes (e.g., SGSN and GGSN) in the GPRS 
network. As shown in FIG.l, one or more GTP tunnels can be used to provide connection paths between a SGSN 
123 and Gateway GPRS Support Node (GGSN) 152. Typically, one GTP tunnel is created per GPRS user at any 
time. GTP tunnels are identified by an associated GPRS user's IP address and each provides a given active GPRS 

20 user a path for communicating with zero to many hosts (i.e., servers) on the packet data network (e.g., the Internet). 
Encapsulation adds additional address and control information to packets received at the entrance to a GTP tunnel, 
allowing the packets to be routed from the GTP tunnel start point to the GTP tunnel endpoint without intermediary 
systems having to inspect the data contained in the pre-encapsulated packet. The encapsulated packet can be 
decapsulated once the packet reaches the GTP tunnel endpoint system (e.g., GGSN 1 52). In a conventional GPRS 

25 system, packets received from a mobile station at an SGSN 123 are encapsulated and pass through a GTP tunnel to 
the GGSN 152. Any number of routing/network components (not shown) can be interposed between the SGSNs 
and the GGSN. 

A generic network firewall is a device that separates yet bridges networks. Network firewalls filter 
network traffic, forwarding legitimate traffic while otherwise processing suspect traffic (e.g., dropping suspect 

30 traffic). A GTP firewall is a generic network firewall that supports the GTP protocol. In the GPRS network, one or 
more GTP firewalls may be provided at the Gn or Gp interfaces in the network. For example in FIG. 1, between the 
SGSN 123 and the GGSN 152 is a Gn interface. A GTP firewall 141 (e.g., Gn firewall) at the Gn interface can be 
used to filter packets that are sent to and received by the SGSN 123. The GTP Firewall 1 41 can be used to ensure 
that the base station subsystems and other system components beyond the SGSN are not vulnerable in the event of 

35 compromise of the GGSN 152. The GTP firewall 141 can inspect packets sent through the interface and apply 
policies to support the security of the SGSN. The GTP Firewall 141 can be configured to inspect tunnel traffic. 
Further, because of its position at the SGSN interface, GTP Firewall 141 has visibility to the creation and tear down 
of GTP tunnels. 

GGSN 152 sends packets to and receives packets from the packet data network through an interface (Gi), 
40 on which a firewall 161 (Gi firewall) can be supported. The Gi firewall 161 can filter packets sent to/from the 
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Internet before allowing the packets to continue on to the GGSN 152. The Gi firewall 161 therefore can provide 
some protection for the GGSN 152 against unsolicited traffic and attacks. 

As noted above, mobile stations 1 15 can access information from the Internet 173 in addition to contacting 
other mobile stations. To receive packets from an Internet site, a mobile station 115 typically needs an IP address to 
5 inform the sender where to route the. packets. Not all mobile stations within a PLMN access the Internet 173 at one 
time, allowing for each PLMN to use a small pool of IP addresses, often fewer IP addresses than mobile stations in 
the network. Individual mobile stations are dynamically assigned PLMN's IP addresses as necessary to support 
requested communications. After communications are complete, the assigned IP addresses can be reused by other 
subscribers (e.g., other mobile stations). When a subscriber wishes to access the Internet 173, the subscriber uses a 

10 mobile station 1 15 to contact the SGSN 123 and is assigned one of the IP addresses from the pool. The assigned IP 
address is identified with the particular mobile station and used in the pre-encapsulated packet header for all packets 
associated with the given user. A GTP tunnel is created from an associated SGSN 123 to the GGSN 152 to allow 
the communication of packets from the mobile station to the external network. Encapsulation of packets occurs and 
data can pass from/to the mobile stations to/from the external network (e.g., the Internet 173). Once the mobile 

15 station 115 ends its connection, a GTP tunnel disconnect event occurs. The IP address associated with the mobile 
station can be returned to the IP address pool where the address can be reassigned to another mobile station 115. 

In conventional GPRS networks, the GGSN 152 can track the GPRS usage or Internet 173 access for each 
mobile station 115. Typically the GPRS usage is tracked according to incoming and outgoing packet traffic rather 
than time spent on the network. The incoming and outgoing packets can be assigned to the IP address in the packet 

20 header that corresponds to the mobile station 1 1 5 using the IP address at the time of transmission. If the network 
continues routing packets to an IP address even after a mobile station 1 15 has disconnected from the network, the 
packet traffic may be attributed to the mobile station 1 15 that last used the IP address and is no longer accessing 
network. This can result in unacceptable charges on the mobile station subscriber's bill. 

Another problem related arises due to reuse of the IP addresses. Typically the pool includes a finite 

25 number of addresses that can be discovered innocently or maliciously. The problem can be illustrated by an 
example. A first mobile station 1 15a attaches to the network and is assigned an IP address. After sending and 
receiving packets from the Internet 1 73 by way of a GTP tunnel 1 35, the first mobile station 115a disconnects. The 
GTP tunnel 135a is torn down and the IP address is returned to the pool of IP addresses. A second mobile station 
1 15b attaches to the system and is assigned the IP address that the first mobile station 1 15a had been using. A new 

30 GTP tunnel 135b is constructed for the second mobile station 1 15b. Packets initiated from the Internet 173 with the 
IP address are routed through the new GTP tunnel 135b to the second mobile station 1 15b, regardless of whether 
the second mobile station 1 15b requested the incoming packets. This is because the second mobile station is now 
associated with the IP address. The packets could have been requested by the first mobile station 1 15a or initiated 
by a server on the Internet 173 that knows the IP address, and is maliciously sending messages. The GPRS usage is 

35 billed to the account associated with the second mobile station 1 15b, again resulting in unacceptable charges. 

Malicious servers 175 on the Internet 173 can discover IP addresses from the pool of IP addresses and send 
packets to the IP addresses, regardless of receiving requests for packets. In conventional GPRS systems, the Gi 
firewall 161 does not clear firewall sessions in response to a GTP tunnel tear down. This can lead to a firewall 
session list not accurately reflecting active firewall sessions. This allows a server to continue to send packets 

40 through the Gi firewall 161 and potentially cause GPRS usage to be assigned to mobile station 115 even when the 
mobile station 1 15 is not requesting the downloaded packets. In addition to the billing problems noted above, 
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unsolicited packets to a mobile station 1 15 can bottleneck a mobile station's receiving line, thereby slowing down 
desired transmissions or preventing the mobile station 1 15 from receiving desired packets. 

SUMMARY 

In general, in one aspect, the invention features a method of screening incoming packets. A request to 
5 establish a connection from a first network to a packet data network is detected. Establishment of a tunnel is 
detected, wherein the tunnel has a support node at each end. One of the support nodes is a gateway to the packet 
data network. The tunnel can be used to convey user traffic through the tunnel, wherein the user traffic can be 
associated with one or more firewall sessions on a firewall outside the tunnel. A tear down of the tunnel is detected. 
A firewall at one of the support nodes generates a request to clear the one or more firewall sessions associated with 
1 0 the torn down tunnel and sends the request to the firewall at the gateway where an associated session list can be 
updated. 

In another aspect, a method of screening incoming packets includes providing a connection from a first 
network to a packet data network, including providing a GTP tunnel having a support node at each end. One of the 
support nodes is a gateway to the packet data network. A tear down of the GTP tunnel is detected. A policy is 

1 5 applied to determine whether to request a firewall session clear at a Gi firewall. 

In yet another aspect, a method of screening incoming packets includes detecting an establishment of a 
firewall session between a mobile station logged onto a GPRS network and a system on a packet data network. An 
end to the firewall session is detected. A request is sent to a Gi firewall protecting the gateway support node from 
attacks from the packet data network to remove the firewall session from a firewall session list. 

20 In another aspect, a method of screening incoming packets includes adding a firewall session identifier to a 

firewall session list when a new firewall session for user traffic coming out of a GTP tunnel is created, where the 
user traffic does not belong to an existing firewall session. Thereafter, the user traffic is allowed to pass. A message 
is received to indicate the firewall session is no longer active. The firewall session is then indicated as no longer 
being active on the firewall session list. 

25 In another aspect, a system for screening incoming packets includes a GTP firewall and a Gi firewall. The 

GTP firewall has a GTP communication module. The Gi firewall has a Gi communication module that is operable 
to receive an instruction from the GTP communication module to tear down a firewall session, a firewall session list 
and a tear down engine that removes inactive firewall sessions from the firewall session list when the tear down 
engine receives the instruction from the GTP communication module. 

30 Aspects of the invention can include one, more or none of the following features. A system is proposed 

that uses the GTP firewall to monitor the tear down of a GTP tunnel and signal the Gi firewall so that related 
firewall sessions are closed. By notifying the Gi firewall that a GTP tunnel is closed, the Gi firewall may drop or 
deny any packets related to the associated closed firewall session before the packets get to the GGSN. By dropping 
packets that are not related to an open firewall session, unsolicited packets may be kept out of a system. The GTP 

35 firewall can alternatively monitor firewall session tear down. A single GTP tunnel can be associated with one or 
more firewall sessions and tearing down the GTP tunnel may cause the one or more associated firewall sessions to 
be removed from or deactivated on the firewall sessions list in the Gi Firewall. 

Malicious servers that send unsolicited packets may be prevented from attacking a system. Unsolicited 
packets may have at least two negative effects. The first may be that unsolicited packet transmission is charged to a 

40 mobile station. Another effect can be that the load on the network is increased when more packets are let into the 
network. At a point in the network where bandwidth is limited, such as between a mobile station and a base station 
subsystem, a bottleneck of transferred packets can occur. Network resources may be freed up if unsolicited traffic 
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is decreased. Additionally, subscribers may be less likely to be billed for unsolicited packet traffic, leading to fewer 
customer complaints and contacts to the PLMN service provider. The dual firewall configuration and signaling can 
be independent of the SGSN and GGSN vendors, which may allow for greater flexibility and security. If the GTP 
and Gi firewalls are controlled by the same entity there is no trust problem for implementing the notification 
5 method. 

The details of one or more embodiments of the invention are set forth in the accompanying drawings and 

the description below. Other features, objects, and advantages of the invention will be apparent from the 

description and drawings, and from the claims. 

DESCRIPTION OF DRAWINGS 
1 0 FIG 1 is a block diagram of a prior art system for packet switched communications between a mobile 

station and land-based system. 

FIG 2 is a block diagram of a packet switched communication system that provides protection from 
unsolicited traffic. 

FIG 3 is a flow chart showing the steps performed by a firewall between a serving support node and a 
1 5 gateway support node. 

FIG 4 is a flow chart showing the steps performed by a firewall on a reference point between the gateway 
support node and a packet data network. 

FIG 5 is a flow chart depicting an alternate method performed by the firewall between the serving support 
node and a gateway support node. 
20 Like reference symbols in the various drawings indicate like elements. 

DETAILED DESCRIPTION 
Referring to FIG. 2, a GPRS network 200 includes firewalls that are configured to provide a solution to the 
problem of unsolicited traffic reaching the GGSN 152. The GPRS network 200 is similar to a conventional GPRS 
network, but includes additional functionality within the firewalls (i.e., GTP Firewall 143 and Gi Firewall 163) that 
25 facilitate communication with one another at the time of tear down of GTP tunnels. 

GTP Firewall 143 includes a communication module 147 that sends messages to and receives messages 
from a communication module 167 in the Gi Firewall 163. The communications can be in-band (using the 
conventional link between the two devices in the GPRS network 200) or out of band (e.g., using an external 
network or signaling system). GTP Firewall 143 includes a detection module 146. Detection module 146 operates 
30 to detect the tear down of GTP tunnels between a SGSN 123 and GGSN 152. More specifically, GTP Firewall 143 
detects tear down by examining the GTP tunnel teardown request and response messages passed between SGSN 
123 and GGSN 152. At tear down, GTP communication module 147 can send instructions to a tear down engine 
165 in the Gi Firewall 163 (via communication module 167 in Gi Firewall 163). 

Gi Firewall 163 includes tear down engine 165 and a flow table (e.g., a firewall session list 169). Gi 
35 Firewall 163 uses the firewall session list 169 to track the currently active firewall sessions related to active GPRS 
users. Typically the firewall session list 169 includes identifiers for the two communicating systems, such as the IP 
address assigned to a particular mobile station 1 15 and an IP address for a server on the Internet 173, along with 
other information, such as a firewall session identifier or policy information regarding inspection of packets 
associated with the firewall session. Typically, the Gi Firewall 163 is configured to create sessions upon receipt of 
40 traffic from GPRS users destined for the packet network (e.g., the Internet). Once sessions are created, returning 
traffic from the packet network to the GPRS users will be allowed to pass for all traffic with matching entries in the 
firewall session list 169. If any traffic originating from the packet network fails to correspond to an entry in the 
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firewall session list 169, Gi Firewall 163 will deny the traffic. Tear down engine 165 in the Gi Firewall 163 is 
operable to remove/delete firewall sessions associated with the torn-down GTP tunnels in its firewall session list 
169. 

Referring to FIGS. 2 and 3, a method is shown for communicating by a GTP Firewall to a Gi Firewall in 
5 the GPRS network 200. GTP Firewall 143 connects via a link (i.e., in-band or out of band) to the Gi Firewall 163 
and sends an initialization request to the Gi Firewall 163 (step 204). In one implementation where the GGSN's 
operator controls both the Gi Firewall 163 and the GTP Firewall 143 the initialization described herein may not be 
required. The initialization request can include a handshake, a hello message, an acknowledgement, and/or an 
authentication request. A check is made to determine if a properly formatted acknowledgement signal has been 
10 returned (step 206). If not, a time out loop is entered (step 208). Upon receipt of an acceptable acknowledgement, 
GTP Firewall 143 thereafter waits until a tear down is detected of a GTP tunnel between the GTP and Gi Firewalls, 
respectively (step 210). As described above, when a mobile station 115 attaches to a network, a GTP tunnel 135 is 
set up to connect an associated SGSN 123 to GGSN 152. The GTP tunnel 135 passes through the GTP Firewall 
143, enabling the GTP Firewall 143 to safeguard the SGSN 123 from packets sent by untrusted GGSNs. The GTP 
1 5 Firewall 143 is operable to recognize that a new GTP tunnel 1 35 has been established and can monitor traffic 
through the new GTP tunnel 135. 

At the time of tear down, the GTP Firewall 143 communicates with the Gi Firewall 163 (e.g., the GTP 
communication module 147 communicates with the Gi communication module 167) to signal to the Gi Firewall 163 
that the GTP tunnel has been torn down (step 212). This process repeats for each GTP tunnel tear down. 
20 Referring now to FIGs 2 and 4, a method is shown for communicating between Gi Firewall to a GTP 

Firewall in the GPRS network 200. The Gi Firewall 163 receives an initialization request from the GTP Firewall 
143 (step 302). Gi Firewall 163 responds with a properly formatted acknowledgement signal (e.g., Gi 
communication module 167 sends the acknowledgement signal to the GTP communication module 147) (step 304). 
As described above, the Gi Firewall 163 maintains a firewall session list 169 that includes firewall session 
25 identifiers for each active firewall session. Each packet can be associated with a firewall session by the packet's 
header information. A mobile station 115 disconnecting from the network ends the associated firewall session. 
When the mobile station 1 15 is disconnected the GTP tunnel 135 is no longer needed to send and receive packets 
from the SGSN 123 to the GGSN 152 and the GTP tunnel 135 can be torn down. As described above, the GTP 
Firewall 143 detects GTP tunnel tear down. 
30 Upon detecting the GTP tunnel tear down, the GTP communication module 147 can send a message to the 

Gi Firewall 1 63 . The message can include specific tear down instructions (e.g., upon receipt of the message (step 
306), Gi Firewall 163 can clear an associated firewall session from the firewall session list 169 (step 308)). In one 
implementation, the message can include a 5 tuple of information including the source IP address, source port, 
protocol, destination IP address and destination port associated with the traffic on a given GTP tunnel that is to be 
35 torn down. Alternatively, the message can include information that can be used by the Gi Firewall 163 that may 
result in the clearing of more than one firewall session from firewall session list 169. As discussed below, the 
message may contain information that is evaluated against one or more policies in order to determine an appropriate 
response by the Gi Firewall 1 63 . 

In one implementation, the Gi Firewall 163 clears the firewall session list 169 and invalidates the IP 
40 address associated with the appropriate mobile station. In one implementation, Gi Firewall 163 examines a firewall 
session wing's hash table associated with a particular zone, and invalidates a wing's source IP address, i.e., the IP 
address of the mobile station. Thereafter, packets thr* the Gi Firewall 163 receives associated with the invalidated 
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firewall session can be dropped, or inspected further to determine whether the packet should be permitted into the 
network. 

In one implementation, in addition to or in lieu of messaging by the GTP Firewall 143 at the time of 
recognition of a GTP tunnel tear down, GTP firewall 143 is configured to send a message to the Gi Firewall 163 if 
5 any form of network attack is detected at the GTP firewall 143. The message content can be of the form of a 
notification, or an instruction so as to alert/control the Gi Firewall 163 so as to ensure the security of the GPRS 
network. 

In one implementation, the GTP Firewall 143 and Gi Firewall 163 use a TCP based protocol for messaging 
that supports TCP md5 digest option (RFC2385) to provide security. The protocol can have a message format of 
10 message header + extension. The message header can indicate the message length in bytes, the message type and 
the transaction ID. The message type can be indicated by a number, such as 1 for a handshake, 2 for a hello, 3 for a 
hello-ACK and 4 for a clear firewall session. The transaction ID can be a unique number or 0 for the hello or the 
handshake. 

In the TCP messaging implementation, the handshake message with an extension can state the message 

15 length, the message type as 1 and that the transaction ID is 0. The extension can include the version, a hello interval 
that the GTP Firewall 143 will wait before sending the hello to the Gi Firewall 163 and a reserved portion. In one 
implementation, the hello interval cannot be zero. The handshake message is sent after the connection is first 
established. In addition to being sent after a connection is established, the message handshake can be sent at any 
time. In one implementation, the hello message has no extension, the message type is 2 and the transaction ID is 0. 

20 In one implementation, the hello acknowledgement message type is 3 and the transaction ID is the same as 

the last known transaction ID or 0 if there was no transaction. The hello acknowledgement can be used to 
acknowledge the last known transaction ID. At the same time that the acknowledgment for a hello is sent, the Gi 
Firewall 163 can acknowledge other previously sent transactions. In one implementation the transaction ID can 
either be random or sequential, but a certain degree of uniqueness is desirable. 

25 In one implementation, the clear firewall session message is message type 4. The transaction ID is a 

unique number that relates to the transaction that is to clear the firewall session. The context-id describes the 
anchor point of a firewall session(s) on Gi firewall. With this protocol, the firewall session can be anchored on a 
security zone. To specify the firewall session that needs to be cleared, a context may be needed in addition to an IP 
address. When a firewall session is cleared or expired, an event log message can be logged. In one 

30 implementation, a firewall session (i.e., a parent firewall session) can have children firewall sessions. In one 

implementation, the clearing of a parent firewall session can clear the parent's children firewall sessions at the same 
time. 

In one implementation, upon detecting that a GTP tunnel is torn down, one of the GTP or the Gi Firewall 
can implement policy management that determines what action to take, as shown in FIG. 5. That is, rather than 

35 immediately invalidating a firewall session, one or more policies can be examined to determine an appropriate 

action. For example, after an event occurs, such as a mobile station 115 detaching from the network, the associated 
GTP tunnel can be torn down. The GTP Firewall 143 is operable to detect the GTP tunnel tear down (step 405). 
The GTP Firewall 143 can determine whether the firewall session associated with the GTP tunnel 135 should be 
cleared by examining one or more policies (step 413). If the GTP Firewall 143 determines that the firewall session 

40 should be cleared (the "yes" branch of step 413) a message can be sent to the Gi Firewall 1 63 requesting that the Gi 
Firewall 163 to clear the firewall session (step 43 1). If the policy decision warrants, no message may be provided 
to the Gi Firewall 163 and the process can continue at step 405. 
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For example, a dropped call may be quickly reinitiated within a time out period that would not necessitate 
the clearing of the firewall session information. Some instances of GTP tunnel tear down can be caused not by a 
deliberate subscriber-prompted disconnect, but rather by loss of signal or other technical breakdown. Often, when a 
disconnect is not intended, the connection is reestablished with a short period of time, such as within two minutes. 
5 Because of this possibility, the GTP Firewall 143 can implement a wait and see policy and decide to leave the 
firewall session active (the "no" branch of step 413). The GTP communication module 147 can wait for a 
predetermined period for a reconnect request to be received. If a reconnect request is not received after the period 
expires, the GTP communication module 147 can send a clear firewall session message to the Gi Firewall 163 (step 
431). If the mobile station attaches back onto the system within the period (the "yes" branch of 422), the GTP 
10 Firewall 143 does not send a clear firewall session message at that time. Requests are allowed to pass through the 
network until another GTP tunnel tear down is detected. The reconnect can be through a new GTP tunnel and 
assigned to the same firewall session. Allowing the GTP Firewall 143 to implement a wait and see policy prevents 
an unnecessary firewall session clear and new add firewall session request. As an alternative to the wait and see 
policy, the GTP Firewall 143 can use other factors to decide whether the clear firewall session message should be 
1 5 sent to the Gi Firewall 1 63 . 

Alternatively or additionally, the Gi Firewall 163 may include a policy engine that is operable to evaluate 
messages from the GTP Firewall 143. The policy engine can be used to determine what action to take upon receipt 
of notice of a GTP tunnel tear down. 

In another implementation, the GTP Firewall 143 not only determines when a GTP tunnel has been torn 
20 down, but also can determine the information associated with packets that are in the GTP tunnel around the time of 
GTP tunnel tear down. The packets that are in the GTP tunnel are encapsulated to ensure proper routing to the end 
of the GTP tunnel. Within the encapsulated packet is source and destination information that does not designate the 
endpoints of the GTP tunnel, but rather the mobile station's IP address and the IP address of the Internet server. 
This information can be used to determine whether particular Internet servers are behaving maliciously. 
25 Additionally, the information can be used by the GTP Firewall 143 in determining whether a firewall session 
related to a GTP tunnel should be cleared from the Gi's firewall session list 169. 

In addition to the messages described above, the GTP Firewall 143 can send a hello message at any time to 
detect a dead connection to the Gi Firewall 163. If a dead connection is detected, the connection can be re- 
established. The GTP Firewall 143 can detect dead connections based on idle time. After a connection is re- 
30 established, all request messages without a reply can be retransmitted. 

The GTP and Gi Firewalls 143, 163 can be separate units or can be implemented in the same unit. The 
protocol that is used between the GTP and Gi Firewalls 143, 163 can be TCP based. This enables the system to be 
used with sites that do not permit UDP traffic. The communication can be separate from other traffic, so that 
communication can be on a private network or other secured channel. The communication between the GTP and Gi 
35 firewall can be UDP based or other packet based mechanisms. Communication between the GTP and Gi Firewall 
can be in-band, out of band, or a variation or change to the conventional communication mechanism between the 
devices (e.g., existing protocols can be adopted and modified as necessary to provide the communication specified 
herein between the devices). 

A firewall can be partitioned into multiple virtual systems. Either or both of the Gi Firewall 163 or GTP 
40 Firewalls 143 can be within a virtual system. Each virtual system is a unique security domain and can be managed 
by administrators who can individualize (e.g., including setting up address books and policies) the security 
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protections for the given domain. The Gi Firewall 163 and GTP Firewall 143 can be either in the same virtual 
system or in different virtual systems. 

Either or both of the firewalls can be operated in a transparent mode (i.e., the firewalls can be run in 
different modes with awareness of routing and application or not). The Gi Firewall 163 and GTP Firewall 143 can 
5 be within the same cluster, but on different VSD groups. A Gi Firewall 163 can be partitioned into multiple virtual 
systems. The firewalls can be run in a 1 :1, n:l active-standby or active-active redundancy configurations. 

A number of embodiments of the invention have been described. Nevertheless, it will be understood that 
various modifications may be made without departing from the spirit and scope of the invention. Accordingly, other 
embodiments are within the scope of the following claims. 
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WHAT IS CLAIMED IS: 

1 . A method of screening incoming packets, comprising: 

detecting a request to establish a connection from a first network to a packet data network; 
detecting establishment of a tunnel, wherein the tunnel has a support node at each end of the 
tunnel, one of the support nodes being a gateway to the packet data network, wherein the tunnel is used to convey 
5 user traffic and the user traffic through the tunnel can have one or more associated firewall sessions on a firewall 
outside the tunnel; 

detecting a tear down of the tunnel; and 

sending a request to the firewall to clear the one or more firewall sessions.. 

2. The method of claim 1, wherein: 

detecting a tear down of the tunnel includes detecting the tear down of a GTP tunnel within the 

first network. 

3 . The method of claim 1 , further comprising: 

stopping passage of packets to the first network originating from the packet data network and 
associated with a firewall session that is not on the firewall session list 

4. The method of claim 1 , further comprising: 

dropping packets originating from the packet data network and not associated with a firewall 
session identifier on the firewall session list. 

5. The method of claim 1, wherein: 

detecting the tear down of the tunnel includes detecting GTP delete tunnel request and response 

messages, 

6. The method of claim 1, further comprising: 

clearing the one or more firewall sessions from a firewall session list. 

7. The method of claim 1, further comprising: 

adding a firewall session to a firewall session list at a time when a new tunnel is created. 

8. The method of claim 1, further comprising: 

inspecting packets in the tunnel to detect firewall session information. 

9. The method of claim 8, wherein: 

determining at least one of a source address and a destination address of the packets in the tunnel. 
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1 0. The method of claim 1 , wherein: 

detecting establishment of the tunnel includes determining the one or more firewall sessions 
associated with the tunnel. 

11. The method of claim 10, wherein: 

detecting establishment of the tunnel includes determining two or more firewall sessions 
associated with the tunnel. 

12. A method of screening incoming packets, comprising: 

providing a connection from a first network to a packet data network including providing a GTP 
tunnel, wherein the GTP tunnel has a support node at each end of the GTP tunnel, one of the support nodes being a 
gateway to the packet data network; 

detecting a tear down of the GTP tunnel; and 

applying a policy to determine whether to request a firewall session clear at a Gi firewall. 

13. The method of claim 12, wherein: 

applying a policy includes waiting for a period for a reconnect event. 

14. The method of claim 13, wherein: 

applying a policy includes not requesting a firewall session clear when a reconnect event is 
received within the period. 

15. The method of claim 12, further comprising: 

inspecting the packets in the GTP tunnel to determine firewall session information. 

16. The method of claim 12, further comprising: 

determining at least one of a source address and a destination address of the packets in the GTP 

tunnel. 

17. A method of screening incoming packets, comprising: 

detecting an establishment of a firewall session between a mobile station logged onto a GPRS 
network and a system on a packet data network; 

detecting an end to the firewall session; and 

sending a request to a Gi firewall protecting the gateway support node from attacks from the 
packet data network to remove the firewall session from an associated firewall session list. 

1 8. A method of screening incoming packets, comprising: 

adding a firewall session identifier to a firewall session list when a new firewall session for user 
traffic coming from a GTP tunnel is created and when the user traffic does not belong to an existing firewall 
session; 
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receiving a message to indicate the firewall session is no longer active; and 
indicating the firewall session is no longer active on the firewall session list. 

19. The method of claim 1 8, wherein: 

indicating the firewall session is no longer active on the firewall session list includes removing 
the active firewall session from the firewall session list. 

20. The method of claim 1 8, wherein: 

indicating the firewall session is no longer active on the firewall session list includes marking the 
firewall session as inactive on the firewall session list. 

2 1 . The method of claim 1 8, further comprising: 

dropping packets associated with the no longer active firewall session. 

22. A system for screening incoming packets, comprising: 

a GTP firewall having a GTP communication module; and 

a Gi firewall having a Gi communication module that is operable to receive an instruction from 
the GTP communication module to tear down a firewall session, a firewall session list and a tear down engine that 
removes inactive firewall sessions from the firewall session list when the tear down engine receives the instruction 
from the GTP communication module. 

23 . The system of claim 22, wherein: 

the GTP firewall is operable to detect a GTP tunnel tear down. 

24. The system of claim 23, wherein: 

the GTP firewall is operable to detect a firewall session end. 

25. The system of claim 22, wherein: 

the GTP firewall includes a Gn firewall provided at a Gn interface. 

26. The system of claim 22, wherein: 

the GTP firewall includes a Gp firewall provided at a Gp interface. 

27. The system of claim 22, wherein: 

the GTP firewall is located on a device; and 
the Gi firewall is located on the device. 

28. A method of screening incoming packets, comprising: 

providing a connection from a GPRS network to a packet data network including providing a GTP 
firewall between support nodes in the GPRS network and a Gi Firewall between a support node operating as a 
gateway to the packet data network and the packet data network; 
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detecting a network attack originating from the packet data network at the GTP firewall; and 
signaling the Gi Firewall to alert the Gi Firewall of the attack. 



29. The method of claim 28 wherein the packet data network is the Internet. 

30. The method of claim 28 wherein signaling the Gi Firewall includes sending a message to the Gi 
Firewall. 

31 . The method of claim 28 wherein signaling the Gi Firewall includes sending a message to clear a 
session in the Gi Firewall. 
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